<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>

    <div>
        <p> 名字是： {{ name }} </p>
        <p> 年龄是： {{ age }} </p>
    </div>

    

    <script>

        const obj = {
            name : 'cc' ,
            age : 20
        }


        const oRoot = document.querySelector('div') ;

        let rootStr = oRoot.innerHTML ;

        console.log(rootStr);


        // 匹配双括号相关的内容
        const reg = /{{ *(\w+) *}}/g ;

        // 找到与正则相匹配的内容
        const arr = rootStr.match(reg) ;
        console.log(arr);

        // 需要一个一个的替换
        arr.forEach(item => {
            // 找到双大括号中的属性   找到匹配的子正则的内容
            const key = reg.exec(rootStr)[1];
            rootStr = rootStr.replace(/{{ *(\w+) *}}/ , obj[key])
        })

        console.log(rootStr);

        oRoot.innerHTML = rootStr ;

    </script>
    
</body>
</html>